# 第1章

# 低コストFPGAを用いた 高速データ・インターフェースの設計



─1GHzアナログ信号のサンプリングと 800MHzのディジタル波形サンプリングを実現する



## Minseok Kim

本章では、高速シリアル・データ伝送のLVDS (low voltage differential signaling) インターフェースとクロックの立ち上がり/立ち下がりの両方のエッジを使う DDR (double date rate) について解説する. (編集部)

## 1. 高速データ・インターフェースを理解しよう

本章ではまず、高速データ・インターフェースの標準として多く使われているLVDS差動インターフェース規格と、リファレンス・クロックの両エッジを用いて転送効率を2倍にすることで、高速データ・レートを実現する方法であるDDRインターフェースについて、市販のFPGAでサポートされる機能を中心に調べてみます。

### ● 差動データ・インターフェース規格のおさらい

現在,世の中で使われている差動伝送規格にはいろいろありますが,その代表的なものはLVDSという差動インターフェース規格です.これを用いると,プリント基盤線

路パターンやケーブルなどのさまざまなメディアを介して, 高速データの転送が可能になります.

LVDS は , IEEE standard 1596.3 SCI-LVDS と ANSI/TIA/EIA-644の二つの工業標準規格で定義されています . 勧告の最大転送速度は , IEEE 規格では250Mbps , ANSI/TIA/EIA-644 規格では655Mbps になっています . LVDSインターフェースは , 最近のFPGA では当たり前のように標準インターフェース規格として提供されています .

米国 Altera 社の場合,ANSI/TIA/EIA-644 規格をベースとし,最速 6.375 Gbps をサポートするハイエンド製品から,Cyclone II のように低コストでありながら十分なチャネル数を持つローエンド製品まで製品化しています(表1).また,米国 Xilinx 社の場合は,Spartan-3 という低コスト製品において,344 個までの差動インターフェース・ペアを提供しています(表2).

これらの低コストFPGAでは、専用のSerDes(シリアライザ・デシリアライザ; Serializer/Deserializer)回路を内蔵せず、その機能を論理ブロック上に実装することで転送

表1 米国Altera 社のFPGA における差動イン ターフェース仕様

| ファミリ名      | チャネル数                       | 最大データ転送速度                         | SerDes内蔵 |
|------------|-----------------------------|-----------------------------------|----------|
| Cyclone    | 34 ~ 129                    | 640 Mbps                          | なし       |
| Cyclone    | 31 ~ 261                    | 805 Mbps                          | なし       |
| Stratix    | 40 ~ 160                    | 840 Mbps                          | あり       |
| Stratix GX | 44 ~ 90<br>(高速チャネル:4 ~ 20)  | 840 Mbps<br>(高速チャネル:3.125 Gbps)   | あり       |
| Stratix    | 80 ~ 312                    | 1.040 Gbps                        | あり       |
| Stratix GX | 60 ~ 144<br>(高速チャネル:4 ~ 20) | 1.040 Gbps<br>(高速チャネル:6.375 Gbps) | あり       |
| Stratix    | ~ 264                       | 1.25 Gbps                         | あり       |

KeyWord

LVDS , DDR , 差動インターフェース , Cyclone , 高速 A-D コンバータ , デマルチプレクサ , AT84AD001B , EP2C8



#### 図1 LVDS の動作原理

線路ペアから電流のリターン・パスができるため,電流ループが小さくなり,EMIの影響を少なくできる.

速度は低下しますが,その代わりに低コスト化を実現しています.

Cyclone II の場合, LVDSから派生したRSDS(reduce swing differential signaling)とmini-LVDSという電圧振幅を小さくし,消費電力を低減した規格についてもサポートしています(出力機能のみ). さらに,クロック・インターフェースとして多く使われるLVPECL(low voltage positive emitter coupled logic)規格は,FPGAのクロック入力専用ピンでサポートされます.

### (1)LVDS **の物理的な特性**

LVDS 規格とシリアライザ・デシリアライザを用いて高速シリアル転送を行うことは,LSI間の配線数が低減でき,基板のコスト削減に直接繋がるという利点があります.さらに,LVDS 規格が差動電流モードのインターフェースであることで,外部からのノイズに対して高い耐性を持つと同時に,クロストーク・ノイズも非常に低いものとなります.差動インターフェースは高速データ転送をするときに高い信頼性があることから,数百 MHz ~数 GHz の高速データ転送規格として広範囲に採用されています.

LVDSの物理的な等価回路を図1に示します.ドライバ側では,およそ3.5mAの電流をスイッチング動作により,その向きを変化させながら約100の終端抵抗に流します.

このような差動ドライバは,大きさが同じで,符号が反対のオド・モード(odd mode)転送を行います.線路ペアから電流のリターン・パスができるため,電流ループが小さくなります.これはEMI(電磁妨害; electromagnetic interference)の影響を少なくすることができます.

表2 米国 Xillinx 社の FPGA における差動インターフェース仕様

| ファミリ名        | チャネル数                         | 最大データ転送速度                       | SerDes内蔵 |
|--------------|-------------------------------|---------------------------------|----------|
| Spartan 3A   | 52 ~ 227                      | 622 Mbps                        | なし       |
| Spartan 3E   | 40 ~ 156                      | 622 Mbps                        | なし       |
| Spartan 3/3L | 56 ~ 344                      | 622 Mbps                        | なし       |
| Virtex-4     | 160 ~ 480<br>(高速チャネル: 0 ~ 24) | 1 Gbps<br>(高速チャネル:10 Gbps)      | あり       |
| Virtex-5     | 200 ~ 600<br>(高速チャネル: 0 ~ 24) | 1.25 Gbps<br>(高速チャネル: 3.2 Gbps) | あり       |



図 $2^{(2)}$  差動信号ペアでは同相ノイズが打ち消し合う(波形データは参考文献(2)を参照)

差動動作により外部からの同相ノイズがうまく打ち消しあい,その出力には 差動信号のみが強め合う.

レシーバでは、図2のように差動動作によって外部からの同相ノイズ(common-mode noise)がうまく打ち消しあい、その出力には差動信号のみが強め合うことになります.
LVDSのノイズ除去効果を最大にするには、線路を同じ長さで対称に配線しなければなりません.また、LVDS線路ペアは、プリント基盤上で可能な限り近くに通るように配線するなど、線路の配線がきわめて重要です.そのほかにも、LVDS線路ペアの配線距離(edge-to-edge)を基準とし、ほかのペアとの距離はその2倍以上にすることや、シングル・エンド線路との距離はその3倍以上離すことなど、LVDS配線におけるいくつかのルールが勧告されています.その詳細については他の文献を参考してください(2).

近年,データ・レートの増大に伴い,厳しいEMC(電磁的両立性;electromagnetic compatibility)条件から電磁波放射問題がシステム設計において重要な考慮事項になっています。システム設計者は一般に,遠方での電磁波放射



電界: お互いに結合され,電気力線が 閉じられるので,外に放射され にくくなる

磁界:線路の外側における磁界は キャンセルされる (b)シングルエンド信号線路 電界:電界が線路から 放射される

磁界:電界と垂直に 放射される

電磁波の放射が少ない

#### 図3 LVDS で電磁波妨害(EMI)が少ない理由

差動信号では、電界は線路ペアの間にうまく結合され、電気力線がお互いに繋がる状態になる、そのとき、磁力線が線路の内側に集中するため、外側に伝搬する電磁界の放射が少なくなる、シングル・エンド信号では、電界は放射線状に発散し、そのとき磁界は円状で線路周りに生成される、これがEMIトラブルの原因となる。

を考慮することになります.電磁波はTEM( transverse electromagnetic)波<sup>注1</sup>としてシールドを通りぬき,空間に 伝搬されることで,さまざまな電磁波妨害を起こすことに なります.前述のように,LVDSではこの問題がかなり解決できます.電磁界問題はソース周辺環境との複雑な相好 作用を生じるため,予測が難しいとされますが,LVDSの 線路ペア構造によって,電磁界を外部に放射しないように うまく分布させることができます.

図3に,LVDS線路ペアとシングル・エンド線路における電流により生じる電界と磁界を示します.LVDS差動信号の場合,電界は線路ペアの間にうまく結合され,電気力線がお互いに繋がる状態になります.そのとき,線路の外側の磁界はビオサバールの法則注2により打ち消され,磁力線が線路の内側に集中します.このようなことから,外側に伝搬する電磁界の放射が少なくなることが分かります.

注1:電界平面と磁界平面がお互い垂直になり,その進行方向にも垂直な電磁波.

注2: 微小電流素の定常電流により生じる磁界を定義する法則. 磁界を電流の右回りに周回積分として定義したのがアンベールの法則.

注3:静電荷により生じる力を定義する法則.

それに比べて、CMOS/TTLなどのシングル・エンド線路の場合、電界はクーロンの法則注3により放射線状になり、そのとき磁界は円状で線路周りに生成されます。この電磁界は空間に広がって外部に伝搬して行くことが分かります。これがEMIのトラブルの原因となるわけです。

以上のように , 同相ノイズに対する耐性と EMI の低減は , LVDS の物理的な構造から得られる効果で $\mathbf{r}^{(2)}$  .

## (2)FPGA を用いたLVDS のアプリケーション

LVDS はさまざまなアプリケーションに採用されています.ここでは, FPGA を用いた高速データ・コンバータのインターフェースを中心に調べてみます.

最近,計測や無線通信応用などで使われている高速 A-D コンバータ(ADC)や D-A コンバータ(DAC)は,数 GHz のサンプリング・レートをサポートしています.このような高速 A-D コンバータの場合,高速データ・バスとして通常は差動インターフェースを採用し,デマルチプレクサ(demultiplexer; demux と表記されることが多い)を用いてインタリーブし,相手のLSIの処理可能な速度まで転送レートを下げる仕組みを取ります.

最近のFPGAでは,LVDSレシーバ(あるいはトランスミッタ)を内蔵します.また,ハード・マクロまたはソフト・マクロで提供されるSerDes機能を用いて,データをシリアル・パラレル変換することにより,さらに処理レートを下げることができます.

システム設計者は、SerDesのシリアル・パラレル変換機能およびFPGAが提供するソフトウェア・プログラマビリティを活用すれば、個々の用途に特化した高性能な処理機能を迅速に実現できるわけです、計測や無線通信などの高速データ・インターフェースのアプリケーションでは、FPGAの差動インターフェース機能は、従来使用していた特定用途向け IC( ASIC: application specific integrated circuit)に代わり、広範囲の高性能なアプリケーション分

図4 Cyclone **で差動**I/O **の構成** 終端抵抗が内蔵されていないため,外 部に100 で終端する(できるだけピ ン近くに配置).



野に手軽に適用することが可能になっています.

図4にCyclone IIの差動インターフェースの構成を示します.LVDSの入力段は100 の抵抗で終端させ,出力段は抵抗ネットワークで構成します.抵抗ネットワークはドライバ出力電圧を減衰させ,LVDS規格に合わせるために実装します.FPGAは差動インターフェースバッファだけでなく,差動終端抵抗を内蔵しているものもありますが,低コストのCycloneシリーズには内蔵されていません.

### ● DDR インターフェースのおさらい

LVDS 差動インターフェースはデータを高速に転送するための物理的な電気規格であり、SerDes はデータの取り扱いにおける方法論であると言えます。それでは、データ・レートを向上させるもう一つの方法として、リファレンス・クロックの立ち上がりと立ち下がりの両エッジを用いるダブル・データ・レート・インターフェースについて、低コスト FPGA でのサポートを中心に調べてみます。

### (1)FPGA の DDR サポートと応用

米国 Altera 社の FPGA には,altddio という DDR インターフェースのマクロ(以下「DDIO マクロ」と呼ぶ)が提供されていまず $^{3}$ )。これを用いると DDR SDRAM のインターフェース実装などを効率的に実現できます. DDIO マクロには,以下の三つの機能があります.

altddio\_in : リファレンス・クロックの両エッジでデータを受信

altddio\_out: リファレンス・クロックの両エッジでデータを送信

altddio\_bidir : リファレンス・クロックの両エッジで データを送受信

このように, DDIOマクロを用いれば, DDR レジスタを用途に合わせて手軽に実装できます. DDR レジスタは, StratixやAPEX II の場合はI/Oブロック(IOE: IO element)で実装されますが, Cycloneシリーズの場合はピンからいちばん近いロジック・アレイ・ブロック(LAB: Logic Array Block)のロジック・エレメント(LE: Logic element)に実装されます.

DDR レジスタは , データのキャプチャと出力をリファレンス・クロックの両エッジで行います . DDR レジスタは DDR SDRAM, DDR2 SDRAM, RLDRAM II, QDR SRAM, QDRII SRAM などのメモリ・デバイスとのイン



図5 Cyclone シリーズでのダブル・データ・レート入力部の実装 クロックの両エッジで取り込んだデータを,立ち上がりエッジで読み込む. 立ち下がりエッジで取り込んだデータを先にする場合は,ddr\_h\_sync\_reg をパイパスする.

ターフェースや, LVDSのSerDesにも利用されます.その応用について以下のように整理しました.

DDR SDRAM, DDR2 SDRAM, RLDRAM IIのメモリ・インターフェース

クロックの両エッジでデータを取り込むことで,リード・ライト・レートは2倍になります.DDRメモリ・インターフェースはSSTL-II,1.8-V HSTL,LVTTL,LVCMOSなどのインターフェース規格をサポートします.

QDR SRAM , QDRII SRAM メモリ・インターフェース DDR のリード・ポートとライト・ポートを別々に用意 し,通常の SDRAM より 4 倍の操作が同時に行える仕様 になります.

高速のデータ・インターフェース

LVDS, LVPECL, PCML, HyperTransport などの 差動規格において, 高速インターフェースを提供します. このようなデータ転送にも DDR が用いられる場合 があります.

その他

カスタム・インターフェースに使用します.

## (2)DDR レジスタの仕組み

Cyclone シリーズにおいて, DDR 入力部は**図**5 のように 実装されます.

DDR入力部は,DDR入力ピンからいちばん近いロジック・アレイ・ブロック(LAB)にある四つのロジック・エレメント(LE)のレジスタから構成されます.DDRデータは前段の二つのレジスタ(p\_edge\_reg,n\_edge\_reg)にフィードされ,上部のレジスタ((p\_edge\_reg)は立ち上が



**図**6 DDR **入力部のタイミング・チャート** クロックの両エッジでキャプチャしたデータは,立ち上がり エッジに同期して出力される.

リエッジでキャプチャし,下部のレジスタ(n\_edge\_reg)は立ち下がリエッジでキャプチャを行います.ddr\_h\_sync\_regとddr\_l\_sync\_regのレジスタは,二つのデータ・ストリームを立ち上がリエッジで同期させます.出力データの順番が,立ち下がリエッジでキャプチャしたデータを先にする場合は,ddr\_h\_sync\_regをバイパスします.

DDR 入力部のタイミングを図6に示します.これは, Stratix や APEX II のように IOE で半クロック・ラッチ (Latch)を用いる方法とは異なります.

図7にCycloneシリーズにおけるDDR出力部を示します.DDR出力部においても,出力ピンからいちばん近いLABのLEが用いられます.二つのレジスタは二つのシリアル・データ・ストリームを同期させ,データ・レートの2倍のクロックでマルチプレクスすることで実現されます.そのタイミングを図8に示します.

ここまで,LVDS差動I/O規格とDDRについて,その基本原理とFPGAでのサポートについて述べました.次に,具体的に低コストのFPGA(Cyclone II ファミリのEP2C8F256)を用いて,高速データ・インターフェースを設計してみましょう.まず,LVDSを活用する例として,"1GHz"高速 A-D コンバータのインターフェースのリファレンス設計を紹介し,それからFPGAのDDR機能を用いて"800MHz"の非同期データ・キャプチャを実現する設計方法について解説します.

## FPGA を用いた高速 A-D コンバータの 差動インターフェースの設計

高速 A-D コンバータを用いて回路を設計するには,先に 説明した FPGA の LVDS 差動インターフェース機能を活用 すれば,実現できることが分かりました.次に,そのイン



図7 Cyclone シリーズでのダブル・データ・レート出力部の実装 二つのレジスタは二つのシリアル・データ・ストリームを同期させ,データ レートの2倍のクロックでマルチプレクスする.



**図**8 DDR **出力部のタイミング・チャート** クロックが" H"(" L")ならマルチプレクサは data\_in\_h ( data\_in\_l )を出力する.

ターフェース回路を設計してみましょう.

A-D コンバータは,2 チャネル,1G サンプル/s対応のもの(米国 Atmel 社の AT84AD001B)を用います.FPGA は低コスト品でありながら,そこそこ高性能である Altera 社の Cyclone II(EP2C8F256)を選定しました.ここでは,高い信頼性で高速にデータを取り込んでメモリに格納する機能を,FPGA に実装することになります.

#### ● データ・キャプチャの仕組み

A-D コンバータの各出力データ・ビットはシリアル信号 化され,個別のLVDS差動ペア信号として送信されます.

デシリアライズ動作を容易にするため,シリアル・データ・クロックも同時に出力します.A-D コンバータから 1G サンプル/s( $f_s$ )でサンプリングされたデータを,**図**9,**図** 10 に示すように1:2の DEMUX モードで500MHz にレート・ダウンして,LVDS バスから FPGA に入力します.

FPGAのLVDSレシーバ仕様を表3に示します.FPGAはスピード・グレード8の場合でも,最大転送レート640Mbpsは可能なので,500MHzは十分に対応可能な帯域であることが分かります.しかし,500MHzの入力データを直接メモリに取り込むことは,FPGA内部のメモリ性能



1:2 DMUXモード, Clock I = ADC I, Clock I = ADC Q

(=CLKI/2)

( = CLKI/4 )

CLKOL

CLKOQはハイインピーダンス

図9 A-D コンパータの高速 デ ー タ ・ イ ン タ ー フェース

最大1G サンブル/s でサン プリングされたデータは , 1:2の DEMUX モード で500MHz にレート・ダ ウンされ , LVDS バスで FPGA に転送される .



## 図10 A-D コンパータ「AT84AD001B (米国Atmel 社) のLVDS データ・パスのタイミング(1:2 DEMUX モード)

サンプリング・クロックはI/Q チャネル共通( CLKI )にした1:2DEMUX モード.同期クロック出力周波数は FPGA 仕様によりサンプリング・クロックの1/4 として使用( CLKI/4 ) .

表 3 Cyclone II LVDS レシーバの性能(1)

| 記号                     | 説明                              | 条件  | - 6 スピード・グレード - 7 スピード・グレード - 8 スピード・グレード |       |     |       |     | 単位    |     |
|------------------------|---------------------------------|-----|-------------------------------------------|-------|-----|-------|-----|-------|-----|
|                        | 市兀 4月                           | ホゖ  | 最小値                                       | 最大値   | 最小値 | 最大値   | 最小値 | 最大値   |     |
|                        |                                 | × 8 | 10                                        | 402.5 | 10  | 320   | 10  | 320   | MHz |
| f HSCLK                | レシーバの入力クロック周波数                  | × 4 | 10                                        | 402.5 | 10  | 320   | 10  | 320   | MHz |
| I_HSCLK                | レシーハの八月グロック同級数                  | × 2 | 10                                        | 402.5 | 10  | 320   | 10  | 320   | MHz |
|                        |                                 | × 1 | 10                                        | 402.5 | 10  | 402.5 | 10  | 402.5 | MHz |
|                        | レシーバの入力データ・レート                  | × 8 | 80                                        | 805   | 80  | 640   | 80  | 640   | MHz |
| HSIODR                 |                                 | × 4 | 40                                        | 805   | 40  | 640   | 40  | 640   | MHz |
| ПОПОВК                 |                                 | × 2 | 20                                        | 805   | 20  | 640   | 20  | 640   | MHz |
|                        |                                 | × 1 | 10                                        | 402.5 | 10  | 402.5 | 10  | 402.5 | MHz |
| SW                     | サンプリング・ウィンドウ                    |     |                                           | 300   |     | 400   |     | 400   | ps  |
| Input jitter tolerance | PLL がロックするのに要求<br>される入力クロック・ジッタ |     |                                           | 500   |     | 500   |     | 550   | ps  |
| t_lock                 | PLL のロック時間                      |     |                                           | 100   |     | 100   |     | 100   | ps  |

を考えると厳しいように思われます.

表4から分かるように,デュアル・ポートRAMをFPGA で実装するには,スピード・グレード7以下の場合に 200MHz 以下という性能しかありません.従って,ここで はAltera社のLVDSマクロのSerDes機能を用いてさらに レート・ダウンを行います.LVDSのSerDesで1:4の× 4モードでシリアル・パラレル変換を行い, 処理レートを1/4 に下げることにします.

これで, FPGA の内部メモリが十分に動作可能なレート である 125MHz( 500MHz ÷ 4 )まで,デュアル・ポート RAMの書き込みクロック・レートを下げることが可能に なります.つまり, A-D コンバータのマルチプレクス動作 とLVDS レシーバの Ser Des を用いることから,サンプリ ング周波数の1/8のレートでメモリ書き込みが行われます.

## コラム〉GHz-サンプリングA-D コンバータの選択

最近, テスト・ソリューションや計測機器, 無線通信業界におけ るデータ変換は,GHzの時代に入りつつあります.これほど高速に データ処理のできるシステムを設計することは,アナログ感覚を持っ たハードウェア設計, FPGA のインターフェース, メモリ, ロジッ ク設計,信号処理,アプリケーション・ソフトウェアの開発にいた るまで、さまざまなエンジニアリング・スキルが必要になることを

意味します.

表 A に現在市販されている GHz サンプリングの A-D コンバータを いくつか挙げてみました.これらには,高速の差動データ・バス・ インターフェース規格である LVDS や ECL(emitter coupling logic) が採用されていることが分かります. ECLや PECL( positive refe renced ECL)で実現されている A-D コンバータは宿命的に消費電力

表A 市販されているGHz-A-D コンパータ(2006年 現在)

| 型名            | メーカ   | データ規格    | 分解能 (ビット) | チャネル数 | サンプルレート<br>(GHz) | 消費電力(W) | 帯域( GHz ) | 電源電圧(V)                     |
|---------------|-------|----------|-----------|-------|------------------|---------|-----------|-----------------------------|
| MAX104        | Maxim | LVPECL   | 8         | 1     | 1                | 5.25    | 2.2       | 5 , 3.3 , -5                |
| MAX108        | Maxim | LVPECL   | 8         | 1     | 1.5              | 5.25    | 2.2       | 5 , 3.3 , -5                |
| ADC08D1500    | NS    | LVDS     | 8         | 2     | 1.5              | 1.9     | 1.7       | 1.9                         |
| ADC08D1000    | NS    | LVDS     | 8         | 2     | 1                | 1.6     | 1.7       | 1.9                         |
| AT84AD001B    | Atmel | LVDS     | 8         | 2     | 1                | 1.4     | 1.5       | 3.3 , 2.25                  |
| AT84AS003     | Atmel | LVDS     | 10        | 1     | 1.5              | 6.5     | 3         | 3.3 , 2.5 , - 5 , - 2.2     |
| AT84AS004     | Atmel | LVDS     | 10        | 1     | 2                | 6.5     | 3         | 3.3 , 2.5 , - 5 , - 2.2     |
| AT84AS008     | Atmel | ELC/LVDS | 10        | 1     | 2.2              | 4.2     | 3.3       | 3.3 , 1.5 , 5 , - 5 , - 2.2 |
| TS83102G0B    | Atmel | ELC/LVDS | 10        | 1     | 2                | 4.6     | 3.3       | 5 , - 5 , - 0.8/1.45        |
| TS83102G0BMGS | Atmel | ELC/LVDS | 10        | 1     | 2                | 4.6     | 3.3       | 5 , - 5 , - 0.8/1.45        |

Maxim: Maxim Integrated Products 社 NS: National Semiconductor 社 Atmel: Atmel Coporation 社

| 表4 | Cyclone II の内部メモリの動作スピード | 1) |
|----|--------------------------|----|
|----|--------------------------|----|

|      |                             | 使用するリソース |                  |             | パフォーマンス          |                  |                  |        |
|------|-----------------------------|----------|------------------|-------------|------------------|------------------|------------------|--------|
| 応用例  |                             |          | M4K メモリ<br>・ブロック | DSP<br>ブロック | - 6スピード<br>・グレード | - 7スピード<br>・グレード | - 8スピード<br>・グレード | HH 477 |
|      | 単純なデュアル・ポートRAM 128 × 36 ビット | 0        | 1                | 0           | 235.29           | 194.93           | 163.13           | MHz    |
| メモリ  | 真のデュアル・ポートRAM 128 × 18 ビット  | 0        | 1                | 0           | 235.29           | 194.93           | 163.13           | MHz    |
| M4K  | FIFO 128 × 16 ビット           | 32       | 1                | 0           | 235.29           | 194.93           | 163.13           | MHz    |
| ブロック | 単純なデュアル・ポートRAM 128 × 36 ビット | 0        | 1                | 0           | 210.08           | 195.0            | 163.02           | MHz    |
|      | 真のデュアル・ポートRAM 128 × 18 ビット  | 0        | 1                | 0           | 163.02           | 163.02           | 163.02           | MHz    |

そのかわりに,8個メモリを用いて,同時に書き込みを行うことになります.

LVDS レシーバの Ser Des 出力は , 八つの異なるタイミングのデータが 64 ビット(8 ビット×8)のワード形式として出力されます . これを図11 のようにビットの順番を揃えてバッファリングを行い , それから LVDS レシーバの同期出力クロック(outclock)に同期して各メモリに書き込みます . 今回用いる A-D コンバータのシリアル・データ・クロックの仕様は , サンプリング・クロックの1/2 と1/4である500MHz と250MHz として設定するようになっています . しかし , 表3のように LVDS レシーバ仕様上の受信同

期クロック(inclock)は $\times$ 4モードで402.5MHzまでに制限されるため、シリアル・データ・クロックを250MHz(1/4レート)に設定しました.これは,FPGAの内部PLL(phase-locked loop)の1個(2個内蔵)をLVDS専用として使用し,そのクロック管理機能から,SerDesに必要なクロックを生成することになります.

#### ● LVDS 機能を用いた論理回路の設計

前述のように,低コストFPGAには専用のSerDes回路が内蔵されていません.この場合,高速インターフェースを実現するには,高性能のSerDes回路の実装が必須です。

が高く,その応用が制限されてしまいます.また,負電源が必要になるなど,システム設計者にとっては非常に扱いにくいものでした.

しかし,米国 National Semiconductor 社や米国 Atmel 社から発売されたものは、8 ビット精度で 1GHz 以上の性能があります.特に Atmel 社2 チャネル品である AT84 AD001B の場合,BiCMOS 技術で 製造され1.4W 程度(1 チャネル当たり 0.7W)の低消費電力化を達成しています.一般に,GHz サンプリング A-D コンバータの出力データを直接相手の LSI に転送することは無理であり,デマルチプレクサに よりレート・ダウンすることになります.

図AにAtmel社のA-Dコンバータの,LVDSデータ・バス・インターフェースの動作例を示します.1Gサンプル/sでA-D変換されたデータは,内蔵のデマルチプレクサから,ボートAとボートBを用いて半分のデータ・レートで出力されます.また,外部のデマルチプレクサICを使用してさらに半分のデータ・レートに落とし,相手のLSIには出力データが1/4のリーズナブルなデータ・レート(250Mサンプル/s)で渡されることになります.高速のデータを扱う場合,FPGAの差動インターフェースサポートやLVDSのトランシーバ機能は,このようなインターフェースを設計する際に非常に役に立ちます.



図A 米国Atmel 社のA-D コンパータ「AT84AD001B」のデータ・ インターフェース

1G サンプル/s で A-D 変換されたデータは,内蔵のデマルチプレクサからポート A とポート B を用いて半分のデータ・レートで出力される.さらに外部のデマルチプレクサ IC( DEMUX )を使用し,相手の LSI には出力データが 1/4 のデータ・レート( 250 MHz )で渡される.



図11 LVDS のSerDes を用いたシリアル-パラレル変換とメモリ・インターフェース

A-D コンバータのマルチプレクス動作とLVDS レシーバの SerDes より , サンプリング周波数の 1/8 のレートで 8 個のメモリを用いて同時に書き込みが行われる . 八つの異なるタイミングのデータが 64 ビット( 8 ビット × 8 )のワード形式として出力され , そのビットの順番を揃えて各メモリに書き込まれる .

これは、設計者が論理ブロック上に実装することになります.しかし、Altera 社の設計ツールのQuartus II で提供されている ALTLVDS というマクロを使えば、高速のSer Des を簡単に実現することができます.

図12と図13に, Quartus II バージョン6.0 (Web Edition,

無償版 )の MegaWizard Plug-In Manager の ALTLVDS を実行した画面を示します. ここで,今回の仕様にあわせてレシーバの設計を行ってみます.

**図**12の設定項目で,チャネル数(number of channels) は A-D コンバータで1:2にデマルチプレクスされた「16」

## コラム〉FPGAの選定

本特集は、FPGAを用いて高速 A-D コンバータの LVDS 差動インターフェースと DDR データ・キャプチャの活用法をテーマとしています。理解を助けるためにターゲット FPGA を選定し、具体的な設計事例を紹介します。今回は、可能な限り低価格のもので実現することを目標にし、米国 Altera 社の Cyclone II を選定することにしました。また、選定上、以下のようなポイントを考慮しました。

LVDS差動チャネル数を含めたポート数

A-D コンバータのインターフェース用のLVDS チャネル(データ32 本+クロック 2 本 + リセットなど = 35 ~ 37 本程度 )と DDR ディジタル・キャプチャ用の入力ポート(16 ビット).

LVDS レシーバの転送性能

500Mbps以上.

PLL数

最低2個(LVDSとFPGA内部のクロック・マネジメントに使用). ゲート容量

実装に十分な LE 数.

内部メモリ容量

多いほどよいのですが、とりあえずチャネルごとに4,096 点程度、以上の条件で、Altera 社 Cyclone II(EP2C8F256、スピード・グレード8)は、77本の差動チャネル、最大640Mbps 程度のLVDS レシーバ転送性能、二つのPLL、8,256 LE、165,888 ビットの内部メモリという仕様なので、想定した機能を実現するには最小限のものでしょう。



図12 ALTLVDS MegaWizard(1)

Quartus II Web Editionの MegaWizard Plug-In Manager を用いてLVDS レシーバの設計を行う. チャネル数( Number on channels )はA-D コンバータで1:2にデマルチプレクスされた"16 "チャネルになり,デシリアライズ・ファクタ( Desirialization factor )は,それぞれのチャネルに対して1:4にレート・ダウンするため"4"になる.

チャネル(ビット)になり、デシリアルライズ・ファクタ (desirialization factor)は、それぞれのチャネルに対して SerDesで1:4にレート・ダウンするので、「4」になります、図13では転送レートの設定を行います。

A-D コンバータからのデータ・レートは1:2でデマルチプレクスされて500Mbps になるので,入力データ・レートは500Mbps となります.Cyclone II では入力クロック・レートが×4モードで最大250MHzまで設定可能で,A-D コンバータの仕様に合わせて250MHz( $f_s$ /4)とします.クロックとデータのタイミングについても,位相調整の設定項目(phase alignment)からPLLを用いて,仕様に合わせた最適なデータ・キャプチャを行うことができるようになっていますが,今回は特に設定を行いません.

今回,LVDSを用いて設計したA-Dコンバータのインターフェース回路(Ivdsserdes.vhd)を,VHDLで記述したものをリスト1に示します.図11のように,16ビットのデマルチプレクスされた入力データをLVDSのSerDesから64ビットに展開して,八つのメモリに1/8レート(125MHz)で並列に書き込む動作を記述しています.

メモリの実装はLVDSと同様に,Altera社のRAM:2-Portマクロを使用しました.ここで,FIFOで実装してもかまいませんが,今回はアドレス操作が可能なデュアル・ポートRAMとしました.

なお, Cyclone II には終端抵抗が内蔵されていないため, ピン近くに100 の抵抗で終端する必要があります. LVDS



図13 ALTLVDS MegaWizard (2)

A-D コンバータからのデータ・レートは1:2でデマルチプレクスされて "500 "Mbps になる.入力クロック・レートはA-D コンバータの仕様に合わせて250MHz(  $f_s/4$  )とする.

|    | From | To            | Assignment Name 🗥 | Value | Enabled |  |
|----|------|---------------|-------------------|-------|---------|--|
| 16 |      | Ш≥clkp[0]     | I/O Standard      | LYTTL | Yes     |  |
| 17 |      | Ш≥clφ[2]      | I/O Standard      | LVDS  | Yes     |  |
| 18 |      | iii αkφ[2](n) | I/O Standard      | LVDS  | Yes     |  |
| 19 | #    |               | I/O Standard      | LVDS  | Yes     |  |
| 20 |      | DDRB(n)       | I/O Standard      | LVDS  | Yes     |  |
| 21 |      | DOAI[0]       | I/O Standard      | LVD5  | Yes     |  |
| 22 |      | ♠ DOAI[0](n)  | I/O Standard      | LVDS  | Yes     |  |
| 23 |      | DOAI[1]       | I/O Standard      | LVDS  | Yes     |  |
| 24 |      | DOAI[1](n)    | I/O Standard      | LVDS  | Yes     |  |

**図**14 Quartus II 6.0 **の** Assignment Manager **上の**I/O **規格の設定** LVDS ポートの設定はボジティブ・ビンやネガティブ・ビン両方をLVDS としてアサインする.

ポートの設定は、ポジティブ・ピンとネガティブ・ピンの 両方をLVDSとして割り当てる必要があります。

**図**14にQuartus IIの Assignment Manager上, そのインターフェース規格を設定した画面を示します.

## FPGA を用いた DDR データ・キャフ チャの設計

それでは, FPGA を活用してダブル・データ・レート・ キャプチャを設計してみましょう.

今回,設計例としたのは,FPGAの入力ポートの論理値を高速でメモリに取り込む機能(FPGA内部クロックを用いる非同期キャプチャ)になります.具体的にこれを用いると,FPGAで「ロジック・アナライザ機能」を実現することが可能です.今回の設計目標は選定した低コストFPGA上で,実現可能な最高の性能を目指します.選定したFPGAを用いることを想定すると,その性能は以下のようになります.

内部PLLから論理ブロックに供給可能なクロック周波

## リスト1 LVDS を用いたA-D コン バータのインターフェー

ス記述 (Ivdsserdes.vhd) 16ビットのDEMUXされ た入力データをLVDSの SerDes から 64 ビットに展 開して、八つのメモリに 1/8 レート( 125MHz )で並 列に書き込むためのデータ

を用意する.

```
LVDSSERDES.vhd
         FIFO 1:4 Mode
     (ADC DEMUX ratio is 1:2)
       by Minseok Kim
__*************
LIBRARY IEEE:
USE IEEE.std_logic_1164.all;
PACKAGE type_package IS
 TYPE slv8ar4 IS ARRAY(1 to 4) OF std logic vector(7 downto 0);
END type_package;
LIBRARY TERE.
USE IEEE.std_logic_1164.all;
USE IEEE.std_logic_arith.ALL;
USE IEEE.std logic UNSIGNED.all;
USE work.util package.ALL;
ENTITY LVDSSERDES IS
    inclock
                :IN std_logic;
   ADC_rx_data :IN std_logic_vector(15 downto 0);
    outclock
                :OUT std_logic;
                :OUT std_logic;
:OUT slv8ar4;
    locked
    ADC DOUT A
    ADC_DOUT_B
                :OUT slv8ar4
END ENTITY LVDSSERDES.
ARCHITECTURE rtl OF LVDSSERDES IS
  COMPONENT ALTLVDS
     PORT
              rx_locked: OUT STD_LOGIC
  END COMPONENT:
  SIGNAL ADC_rx_out
                                : std_logic_vector(63 downto 0);
BEGIN
-- DOIA > | NI-4 > | NI-2 > | < -- DOIB > | NI-3 > | NI-1 > | < -- DOQA > | NQ-4 > | NQ-2 > | < -- DOQB > | NQ-3 > | NQ-1 > | <
-- CLKOI ~~
   -- 図 12,図 13で作られたLVDSレシーバ ALTLVDSマクロ
    altera_lvds_ADC : ALTLVDS PORT MAP
           (rx_in
                      => ADC_rx_data,
            rx_inclock => inclock,
           rx_out
                       => ADC_rx_out,
            rx_outclock => outclock,
           rx_locked => locked);
-- RAM に取り込むデータワードの作り (Aポート 4 個 + Bポート 4 個で , 8 個データを出力)
   outdata_loop: FOR i IN 0 TO 3 GENERATE
    ADC DOUT A(i+1) <=
               ADC_rx_out(63-i) & ADC_rx_out(59-i) & ADC_rx_out(55-i) & ADC_rx_out(51-i) &
               ADC_rx_out(47-i) & ADC_rx_out(43-i) & ADC_rx_out(39-i) & ADC_rx_out(35-i);
    ADC DOUT B(i+1) <=
               ADC_rx_out(31-i) & ADC_rx_out(27-i) & ADC_rx_out(23-i) & ADC_rx_out(19-i) &
               ADC_rx_out(15-i) & ADC_rx_out(11-i) & ADC_rx_out( 7-i) & ADC_rx_out( 3-i);
    END GENERATE;
END ;
```

数: 402.5 MHz以下(表5から)

内部メモリの動作周波数:約200MHz以下(表4から)

PLL の数量: 2個

以上のことから,ディジタル入力に対してPLLの最大周波数である402.5MHz(グレード8)のダブル・レートでデータのキャプチャが行えるなら,800Mサンプル/s程度の性能を得られそうです.つまり,800Mサンプル/sのキャプチャを達成するには,FPGAの内部PLLからほぼ最大出力周波数である400MHzのクロックを生成し,その立ち上がり/立ち下がりの両エッジでキャプチャを行うことになります.

また,メモリの動作クロック周波数についても,LVDS の場合と同様に,書き込みレートを正常動作可能な周波数まで下げる必要があります.これは,図15のように複数の異なる位相(例えば,0度,90度,180度,270度など)のクロック(あるいはライト・イネーブル)を生成し,それぞれの位相に対応するメモリに取り込む動作になります.この場合,PLLを用いて複数のクロックの位相関係保証やFPGAのグローバル・クロック数も限られていることから,低コストFPGAでの設計が難しいと考えられます.

また,応用によってキャプチャ・レートを可変にするために,ベース・クロックのレートを切り替える必要が出てきます.しかし,ベース・クロックが切り替えられたときに,複数のクロックそれぞれの位相関係が崩れないように対応しないといけないなど,その方法ではいろいろな問題がありそうです.

### ● データ・キャプチャの仕組み

最終的に,どういう仕組みで800M サンプル/s といった 高速キャプチャが実現できるのでしょうか.

図16に, FPGAのディジタル入力ポート(POD)から複数のメモリ・ブロックに書き込みを行うまでの構成を示します. PODの電圧レベルはFPGAのLVTTL I/Oバッファにより3.3V ロジックで"H"か"L"という論理値として現れます. その論理値は, DDRバッファによりクロック(POD

表5 Cyclone II のPLL 仕様<sup>1)</sup>

| 記号                            | パラメータ                        | 最小値 | 最大値   | 単 位 |
|-------------------------------|------------------------------|-----|-------|-----|
|                               | 入力周波数<br>( - 6スピード・グレード)     | 10  |       | MHz |
| fin                           | 入力周波数<br>( - 7スピード・グレード)     | 10  |       | MHz |
|                               | 入力周波数<br>( - 8スピード・グレード)     | 10  |       | MHz |
| fin Duty                      | 入力クロック・<br>デューティ・サイクル        | 40  | 60    | MHz |
| fourt out                     | PLL 出力周波数<br>( - 6スピード・グレード) | 10  |       | MHz |
| fout_ext<br>(外部PLL<br>クロック出力) | PLL 出力周波数<br>( - 7スピード・グレード) | 10  |       | MHz |
|                               | PLL 出力周波数<br>( - 8スピード・グレード) | 10  |       | MHz |
| fourt                         | PLL 出力周波数<br>( - 6スピード・グレード) | 10  | 500   | MHz |
| fout<br>(グローバル・<br>クロックへ)     | PLL 出力周波数<br>( - 7スピード・グレード) | 10  | 450   | MHz |
|                               | PLL 出力周波数<br>( - 8スピード・グレード) | 10  | 402.5 | MHz |
| f_vco                         | PLLinside(内部)<br>VCO動作範囲     | 300 | 1000  | MHz |



図 15 位相の異なる複数のクロックを用いたデータ・キャ プチャ

複数の異なる八つの位相(0,45,90,135,180,225,270,315度)のクロックを生成し,それぞれの位相に対応するメモリに取り込む動作.低コストFPGAではクロック位相の管理が難しい.



### 図16 並列メモリ書き込みの仕組み

ALTDDIO\_IN を用いると DDR バッファが入力ポート近くの最適な場所に生成される.1:2 デシリアライザを 2 段にすることで 2 チャネルの 1:4 デシリアライザを構成 し,各データを POD\_qclk に同期して八つのメモリに書き込む.



図 17 並列メモリ書き込みタイ ミング

PLLから生成された POD \_clk( Max400MHz )に同期して DDR パッファに取り込み,それからデシリアライザによりレート・ダウンを行う.

\_clk )の立ち上がり/立ち下がりの両エッジでキャプチャされ, それぞれのデータはクロックの立ち上がりエッジで同期出力されます.ここで, POD\_clk が最大400MHz であれば, キャプチャ・レートは800M サンプル/s になります.

DDR バッファは Altera 社の DDIO マクロ(ALTDDIO \_IN)を用いて実装できます.DDR バッファで両エッジにキャプチャされたデータは1:4の DESER(deserializer) モジュールに入力され,最終的に八つの異なる位相でキャプチャしたデータが得られます.すべての出力データは,POD\_qclk の立ち上がりエッジで同期しているため,メモリの実装が簡単になります.

**図**17に**図**16の構成のタイミングを示します.このように,DDIOマクロを用いたダブル・データ・レート・キャ



図18 MegaWizard **による**ALTDDIO\_IN **の設定画面** 入力のワード長のみ設定すればOK.

リスト2 16 ピット1:2 デシリ アライザのVHDL 記述 (DESERx2.vhd) 16 ピット・データをク

16 ビット・データをクロックの両エッジで取得し,立ち上がリエッジに同期して出力する.

```
deserx2.vhd
        by Minseok Kim
LIBRARY IEEE;
USE IEEE.std_logic_1164.all;
USE work.util_package.ALL;
ENTITY DESERV2 IS
 PORT (
   DTN
               :IN std logic vector(15 downto 0);
               :IN std logic;
    inclock
               :OUT std_logic_vector(15 downto 0);
    OUTDATAL
             :OUT std_logic_vector(15 downto 0)
    OUTDATAH
END ENTITY DESERx2;
ARCHITECTURE rtl OF DESERx2 IS
  SIGNAL n_edge_reg, p_edge_reg : std_logic_vector(15 downto 0);
  SIGNAL ddr_l_sync_reg, ddr_h_sync_reg : std_logic_vector(15 downto 0);
BEGIN
   -- ウちトがりてッジでキャプチャ
   PROCESS (inclock) IS
     REGIN
       IF (inclock'event AND inclock ='1') THEN
         p_edge_reg <= DIN;</pre>
       END IF:
     END PROCESS;
   -- 立ち下がりエッジでキャプチャ
    PROCESS (inclock) IS
       IF (inclock'event AND inclock ='0') THEN
         n_edge_reg <= DIN;
       END IF;
     END PROCESS;
   -- 立ち下がりエッジでキャプチャしたデータは半クロック遅延
    PROCESS (inclock) IS
     BEGIN
       IF (inclock'event AND inclock ='1') THEN
         ddr_l_sync_reg <= n_edge_reg;
       END IF:
     END PROCESS:
    OUTDATAH(15 downto 0) <= p edge reg;
    OUTDATAL(15 downto 0) <= ddr 1 svnc reg;
END ;
```

### リスト3 16 ビット1:4 デシリアライザの VHDL 記述(deserx4.vhd)

2入力の16ビット・データを1:4にデシリアライズし,8ワード(128ビット)データを時間順に並べ変えて出力する.

```
deserx4.vhd
        by Minseok Kim
LIBRARY IEEE;
USE IEEE.std_logic_1164.all;
USE work.util_package.ALL;
ENTITY DESERX4 IS
 PORT (
   DIN L
                :IN std_logic_vector(15 downto 0);
   DIN H
               :IN std_logic_vector(15 downto 0);
   inclock
               :IN std_logic;
   outclk
               :OUT std_logic;
   reset
               :IN std logic;
   OUTDATA
               :OUT std logic vector(127 downto 0)
END ENTITY DESERx4:
ARCHITECTURE rtl OF DESERX4 IS
  COMPONENT DESERX2 IS
   PORT (
                  :IN std_logic_vector(15 downto 0);
                 :IN std_logic;
      inclock
      OUTDATAL
                 :OUT std_logic_vector(15 downto 0);
      OUTDATAH :OUT std_logic_vector(15 downto 0)
  END COMPONENT:
  SIGNAL hclock, qclock, reset_sig
                                                   : std_logic;
  SIGNAL dout_LL, dout_LH, dout_HL, dout_HH
                                                   : std_logic_vector(15 downto 0);
  SIGNAL dout_LLL, dout_LLH, dout_LHL, dout_LHH
                                                   : std_logic_vector(15 downto 0);
 SIGNAL dout HLL, dout HLH, dout HHL, dout HHH
                                                   : std logic vector(15 downto 0);
 BEGIN
     非同期セット付きDFFからハーフ・クロックを生成
   PROCESS (inclock) IS
       IF reset = '1' THEN
         hclock <= '1';
       ELSIF inclock'event and inclock = '0' THEN
         hclock <= not hclock;
       END IF;
     END PROCESS:
```

プチャ機能の活用とDESER モジュールの設計により,八つのデータは100MHz(キャプチャ・レートの1/8)のクロックで,それぞれのメモリに対して書き込まれることが分かります.このようにすれば,低コストのFPGAを用いても最大800Mサンプル/sの高速のデータ・キャプチャが実現できます.

## ● DDIOマクロを用いた論理回路の設計

FPGAのDDR機能は、Altera社のMegaWizardを用いてALTDDIO\_INマクロを実装すれば手軽に実装できます。このマクロの入力はFPGAの入力ピンのみになります。これを用いると、ダブル・データレート・バッファは入力ポートの近くに効率良く配置されます。

図18に MegaWizard の設定画面を示します.普通の場

合なら,設定するのは入力のワード長のみになります.

さらに,**図**16のようにデシリアライザ(DESER)を実装する必要があります.DDIOマクロを利用したいところですが,残念ながら入力ポートがピンのみに限定されています.従って,**図**5のような回路を直接論理ブロック上に実装することにしました.

リスト2とリスト3は,それぞれ16ビット入力の1:2(deserx2.vhd)と,2入力1:4デシリアライザ(deserx4.vhd)の VHDL記述を示しています.リスト3では,2入力の16ビット・データを1:4にデシリアライズし,8ワード(128ビット)データを時間順に並べ変えて出力します.

リスト4では,図16のようにメモリ書き込み用のデータ・バッファまでの回路を記述しています.また,高速回路設計の場合,開発ツール(例えば,Quartus IIなど)を用

```
リセット信号をハープクロック遅延
    PROCESS (hclock) IS
       IF hclock'event and hclock = '0' THEN
         reset sig <= reset;
       END IF;
      END PROCESS;
   -- 非同期セット付き DFF からクォータ・クロックを生成
    PROCESS (hclock) IS
      BEGIN
       IF reset_sig = '1' THEN
         gclock <= '0';
       ELSIF hclock'event and hclock = '0' THEN
         qclock <= not qclock;</pre>
       END IF:
     END PROCESS:
    outclk <= gclock:
    - 1st ステージ
   DESERx2 stage L : DESERx2 PORT MAP (DIN
                                                 => DIN L, inclock => hclock,
                                        OUTDATAL => dout LL, OUTDATAH => dout LH);
                                                => DIN_H, inclock => hclock,
    DESERx2_stage_H : DESERx2 PORT MAP (DIN
                                        OUTDATAL => dout_HL, OUTDATAH => dout_HH);
    - 2nd ステージ
   DESERx2_stage_LL : DESERx2 PORT MAP (DIN
                                                 => dout_LL, inclock => qclock,
                                        OUTDATAL => dout_LLL, OUTDATAH => dout_LLH);
    DESERx2_stage_LH : DESERx2 PORT MAP (DIN
                                                 => dout_LH, inclock => qclock,
                                        OUTDATAL => dout_LHL, OUTDATAH => dout_LHH);
    DESERx2_stage_HL : DESERx2 PORT MAP (DIN
                                                => dout_HL, inclock => qclock,
                                        OUTDATAL => dout_HLL, OUTDATAH => dout_HLH);
    DESERx2_stage_HH : DESERx2 PORT MAP (DIN
                                                => dout_HH, inclock => qclock,
                                        OUTDATAL => dout_HHL, OUTDATAH => dout_HHH);
    OUTDATA <= dout_HHH & -- 8th
              dout_LHH & -- 7th
dout_HLH & -- 6th
              dout_LLH & -- 5th
              dout HHL & -- 4th
              dout_LHL & -- 3rd
              dout HLL & -- 2nd
              dout_LLL;
END ;
```

いて論理合成と配置配線を行う際に,クロックになる信号に は正しく周波数設定をすることは必須なので,要注意です.

## Minseok Kim

### (株)プレインズ

## 参考・引用\* 文献

- (1) Altera; Cyclone II Device Handbook, Volume 1, 2006.
- (2)\* National Semiconductor; "LVDS Owner's Manual, "3rd Edition (http://lvds.national.com/), 2004.
- (3) Altera; "altddio Megafunction User Guide," Jul. 2006.
- (4) 西本桃子; 低コスト FPGA による 640Mbps LVDSインターフェースの実現, Design Wave Magazine, 2005年9月号, pp.108-115.

### <筆者プロフィール> -

金 භ 錫 (Minseok Kim). 韓国 Hanyang 大学 電気工学科卒. 横浜国立大学 大学院 博士課程修了. ブレインズ入社以来,組み込みシステム・ベースの電子機器開発に従事.現在,横浜国立大学にて,スマート・アンテナ(Smart Antenna)やソフトウェア無線(Software Defined Radio)に関わる研究に従事. リスト4 DDIO マクロを用いた データ・キャプチャ・ インターフェース記述 (top.vhd から抜粋)

図16のようなメモリ書き 込み用データ(POD\_IN) を作成するまでの回路.

```
-- ALTDDIO INを用いて構成したDDIOコンポーネント
COMPONENT altera_ddr IS
     PORT
             ) :
END COMPONENT:
-- 16 ビット1:4 デシリアライザ・コンポーネント
COMPONENT DESERX4 IS
 PORT (
   DIN L
                      :IN std logic vector(15 downto 0);
   DIN H
                      :IN std logic vector(15 downto 0);
   Inclock :IN std_logic;
Outclk :OUT std_logic;
                      :IN std logic;
           :OUT std_logic_vector(127 downto 0)
END COMPONENT;
(中略)
...>|<D0 >|<D1 >|<D2 >|<D3 >|<D4 >|<D5 >|<D6 >|
---- POD
---- POD clk
              _|~~~~|___|~~~~|___|~~~~|
                             ---- POD_IN_buf_1 > | <
                                                               D4
---- POD IN_buf_h
  -- ダブル・データレート・バッファ
 altera_ddr_inst : altera_ddr PORT MAP (
           datain => (POD2 & POD1),
inclock => POD_clk,
           dataout_h => POD_IN_buf_h,
           dataout_l => POD_IN_buf_l);
  -- 1:4デシリアライザ
 deser_inst : DESERx4 PORT MAP (
           DIN_L => POD_IN_buf_1,
DIN_H => POD_IN_buf_h,
           inclock => POD_clk, -- Max 400MHz
outclk => POD_qclk, -- Max 100MHz
reset => DPRAMCtrlPODReg(2),
           OUTDATA => POD_OUTD);
   PROCESS (POD_qclk) IS
     BEGIN
       IF (POD gclk'event AND POD gclk ='1') THEN
        POD IN(1) <= POD OUTD( 15 downto 0);
         POD IN(2) <= POD OUTD(31 downto 16);
         POD IN(3) <= POD OUTD( 47 downto 32);
         POD_IN(4) <= POD_OUTD(63 downto 48);
         POD_IN(5) <= POD_OUTD( 79 downto 64);
         POD_IN(6) <= POD_OUTD( 95 downto 80);
         POD_IN(7) <= POD_OUTD(111 downto 96);
         POD_IN(8) <= POD_OUTD(127 downto 112);
       END IF:
     END PROCESS:
(中略)
```

DESIGN WAVE MOOK 好評発売中

## 組み込みソフトウェア開発スタートアップ

ITエンジニアのための組み込み技術入門

Design Wave Magazine編集部 編 B5 変型判 244ページ 定価 2,310 円(税込) ISBN4-7898-3719-X

CQ出版社 〒170-8461 東京都豊島区巣鴨1-14-2 販売部 ☎ (03)5395-2141 振替 00100-7-10665